<template>
	<view>
		<view class="content">
			<view class="list" v-if="addressList.length>0">
				<view class="row" v-for="(row,index) in addressList" :key="index" @tap="select(row)">
					<view class="left">
						<view class="head">
							{{row.head}}
						</view>
					</view>
					<view class="center">
						<view class="name-tel">
							<view class="name">{{row.name}}</view>
							<view class="tel">{{row.tel}}</view>
							<view class="default" v-if="row.isDefault">
								默认
							</view>
						</view>
						<view class="address">
							{{row.region.label}} {{row.detailed}}
						</view>
					</view>
					<view class="right">
						<view class="icon bianji" @tap.stop="edit(row)">
							<!-- <image src="/static/编辑.png" mode=""></image> -->
						</view>
					</view>
				</view>
			</view>
			<view class="empty" v-else>
				<u-empty mode="data">
				</u-empty>
			</view>
		</view>
		<view class="add">
			<view class="btn" @tap="add">
				<view class="icon tianjia"></view>新增地址
			</view>
		</view>
	</view>
</template>
<script>
	export default {
		data() {
			return {
				isSelect: false,
				addressList: [
					// {
					// 	id: 1,
					// 	name: "大黑哥",
					// 	head: "大",
					// 	tel: "18816881688",

					// 	region: {
					// 		"label": "广东省-深圳市-福田区",
					// 		"value": [18, 2, 1],
					// 		"cityCode": "440304"
					// 	},
					// 	detailed: '深南大道1111号无名摩登大厦6楼A2',
					// 	isDefault: true
					// },
					// {
					// 	id: 2,
					// 	name: "大黑哥",
					// 	head: "大",
					// 	tel: "15812341234",

					// 	region: {
					// 		"label": "广东省-深圳市-福田区",
					// 		"value": [18, 2, 1],
					// 		"cityCode": "440304"
					// 	},
					// 	detailed: '深北小道2222号有名公寓502',
					// 	isDefault: false
					// },
					// {
					// 	id: 3,
					// 	name: "老大哥",
					// 	head: "老",
					// 	tel: "18155467897",

					// 	region: {
					// 		"label": "广东省-深圳市-福田区",
					// 		"value": [18, 2, 1],
					// 		"cityCode": "440304"
					// 	},
					// 	detailed: '深南大道1111号无名摩登大厦6楼A2',
					// 	isDefault: false
					// },
					// {
					// 	id: 4,
					// 	name: "王小妹",
					// 	head: "王",
					// 	tel: "13425654895",

					// 	region: {
					// 		"label": "广东省-深圳市-福田区",
					// 		"value": [18, 2, 1],
					// 		"cityCode": "440304"
					// 	},
					// 	detailed: '深南大道1111号无名摩登大厦6楼A2',
					// 	isDefault: false
					// },
				]
			};
		},
		onShow() {
			this.$http.get('/userAddress/listbyid').then(res => {
				console.log('shuju', res);
				if (res.code == 200) {
					// this.addressList = res.result
					this.addressList = res.result.map(item => {
						return {
							...item,
							isDefault: JSON.parse(item.isDefault)
						}
					})
					console.log('suiji', this.addressList);
				}
			})

			uni.getStorage({
				key: 'delAddress',
				success: (e) => {
					let len = this.addressList.length;
					if (e.data.hasOwnProperty('id')) {
						for (let i = 0; i < len; i++) {
							if (this.addressList[i].id == e.data.id) {
								this.addressList.splice(i, 1);
								break;
							}
						}
					}
					uni.removeStorage({
						key: 'delAddress'
					})
				}
			})
			uni.getStorage({
				key: 'saveAddress',
				success: (e) => {
					let len = this.addressList.length;
					if (e.data.hasOwnProperty('id')) {
						for (let i = 0; i < len; i++) {
							if (this.addressList[i].id == e.data.id) {
								this.addressList.splice(i, 1, e.data);
								break;
							}
						}
					} else {
						let lastid = this.addressList[len - 1];
						lastid++;
						e.data.id = lastid;
						this.addressList.push(e.data);
					}
					uni.removeStorage({
						key: 'saveAddress'
					})
				}
			})
		},
		onLoad(e) {
			if (e.type == 'select') {
				this.isSelect = true;
			}
		},
		methods: {
			edit(row) {
				uni.setStorage({
					key: 'address',
					data: row,
					success() {
						uni.navigateTo({
							url: "edit/edit?type=edit"
						})
					}
				});

			},
			add() {
				uni.navigateTo({
					url: "edit/edit?type=add"
				})
			},
			select(row) {
				//是否需要返回地址(从订单确认页跳过来选收货地址)
				if (!this.isSelect) {
					return;
				}
				uni.setStorage({
					key: 'selectAddress',
					data: row,
					success() {
						uni.navigateBack();
					}
				})
			}
		}
	}
</script>

<style lang="scss">
	view {
		display: flex;
	}

	.icon {
		// &.bianji {
		// 	&:before{content:"\e61b";}
		// }
		// &.tianjia {
		// 	&:before{content:"\e81a";}
		// }
	}

	.empty {
		display: flex;
		// justify-content: center;  // 水平居中
		// align-items: center;      // 垂直居中
		margin: 0px 165px;
		height: 100vh; // 让容器的高度占满整个视口
	}

	.add {
		position: fixed;
		bottom: 0;
		width: 100%;
		height: 120upx;
		justify-content: center;
		align-items: center;

		.btn {
			box-shadow: 0upx 5upx 10upx rgba(0, 0, 0, 0.4);
			width: 70%;
			height: 80upx;
			border-radius: 80upx;
			background-color: #f06c7a;
			color: #fff;
			justify-content: center;
			align-items: center;

			.icon {
				height: 80upx;
				color: #fff;
				font-size: 30upx;
				justify-content: center;
				align-items: center;
			}

			font-size: 30upx;
		}
	}

	.list {
		flex-wrap: wrap;

		.row {
			width: 96%;
			padding: 20upx 2%;

			.left {
				width: 90upx;
				flex-shrink: 0;
				align-items: center;

				.head {
					width: 70upx;
					height: 70upx;
					background: linear-gradient(to right, #ccc, #aaa);
					color: #fff;
					justify-content: center;
					align-items: center;
					border-radius: 60upx;
					font-size: 35upx;
				}
			}

			.center {
				width: 100%;
				flex-wrap: wrap;

				.name-tel {
					width: 100%;
					align-items: baseline;

					.name {
						font-size: 34upx;
					}

					.tel {
						margin-left: 30upx;
						font-size: 24upx;
						color: #777;
					}

					.default {

						font-size: 22upx;

						background-color: #f06c7a;
						color: #fff;
						padding: 0 18upx;
						border-radius: 24upx;
						margin-left: 20upx;
					}
				}

				.address {
					width: 100%;
					font-size: 24upx;
					align-items: baseline;
					color: #777;
				}
			}

			.right {
				flex-shrink: 0;
				align-items: center;
				margin-left: 20upx;

				.icon {
					justify-content: center;
					align-items: center;
					width: 80upx;
					height: 60upx;
					border-left: solid 1upx #aaa;
					font-size: 40upx;
					color: #777;

					image {
						width: 25px;
						height: 25px;
					}
				}
			}
		}
	}
</style>